## PARTE I (sem consulta)

## NOTA: Não é permitida a presença de calculadoras e telemóveis na sala

- 1. NOTA: Use <u>no máximo 40 palavras</u> para responder a cada uma das 5 alíneas seguintes:
  - a) Diga o que distingue uma excepção duma interrupção.
  - b) Numa arquitectura *pipelined*, qual o tipo de *hazards* que se pretendem resolver com técnicas de predição? Justifique minimamente a resposta.
  - c) Indique os aspectos fundamentais que caracterizam o modelo hierárquico dos sistemas de memória dos computadores actuais.
  - d) Descreva de forma sucinta a tarefa executada pela instrução do MIPS "lui \$1, 0x2349".
  - e) Diga o que entende por estratégia callee saved.
- 2. Desenhe o diagrama de blocos de uma arquitectura de 32 bits para multiplicação de inteiros. Identifique os elementos operativos, de estado e de controlo, e a dimensão dos barramentos.
- 3. Considere que o conteúdo dos registos **\$f2** e **\$f4** é respectivamente:

- a) Obtenha a representação das quantidades armazenadas naqueles registos na forma ±0,m \* 2<sup>exp</sup>, em que "**m**" e "**exp**" estão em decimal, sabendo que estão codificadas segunda a norma IEEE 754.
- b) Determine o resultado da instrução **mul.s \$f12, \$f2, \$f4**, realizando, <u>em binário</u>, os passos necessários à sua obtenção pela **FPU**. Explicite, em binário, o conteúdo do registo **\$f12** após a execução da instrução.
- 4. Considere, na **figura 2** fornecida em anexo, o trecho de código *Assembly* ali apresentado. Admita que o valor presente em **\$PC** corresponde ao *label* "**fc1:**", que nesse instante o conteúdo dos registos é o indicado, e que vai iniciar-se o "instruction fetch" da próxima instrução. Considere ainda o *datapath* e a unidade de controlo fornecido na próxima página, no pressuposto de que corresponde a uma implementação simplific —ciclo sem *pipelining*. Note que este *datapath* é ligeiramente diferente do estudado nas aulas.
  - a) Escreva, nas duas colunas do lado direito da fig.2, <u>em hexadecimal</u>, o endereço em que se encontra armazenada cada uma das instruções do código fornecido, e o respectivo conteúdo, sabendo que a primeira linha corresponde à instrução presente no *label* "fc1:".
  - b) Preencha a tabela fornecida em anexo com o nome de cada uma das fases de execução da **0x0040004C**, e com o valor que tomam, em cada uma delas, os sinais do *datapath* e os sinais de controlo ali indicados. Admita que o valor lógico "1" corresponde ao estado activo. Não se esqueça de preencher o cabeçalho (nome, curso e N.M).
  - c) Sabendo que a frequência do relógio do CPU é de 1 GHz, determine o tempo total que demora a executar o código fornecido, desde o instante inicial do *instruction fetch* da instrução presente em "fc1:" até ao momento em que vai iniciar-se o *instruction fetch* da instrução presente em "next:". Justifique adequadamente a sua resposta.
  - d) A versão alterada do *datapath* fornecido permite a execução de uma instrução que não era suportada pelo *datapath* original estudado nas aulas. Determine qual é essa instrução, <u>justificando</u> adequadamente a sua resposta.

<u>Cotações:</u> 1a) a 1e) -0.6; 2-2.0; 3a) -1; 3b) -1.5; 4a) -1.0; 4b) -1.5; 4c) -1.0; 4d) -1.0



| Nome:                                                                                                                    |                                                                        |                      |       |         |          |           |          |        |
|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|----------------------|-------|---------|----------|-----------|----------|--------|
| Curso:                                                                                                                   |                                                                        |                      |       |         | _Nº Meca | nográfico | ):       |        |
| fc1: ori \$8, \$0, 0<br>lui \$9, 0x10<br>loop: sw \$8, 0x10<br>addi \$8, \$8, -:<br>add \$9, \$9, \$<br>bne \$8, \$0, lo | 001 0<br>C(\$9) 0x03<br>2 0x05<br>0x08<br>0x0D<br>0x0F<br>0x23<br>0x2b | 0x20<br>0x21<br>0x22 |       | reg \$5 |          |           | Endereço | Código |
|                                                                                                                          | Fase 1                                                                 | F                    | ase 2 | Fa      | ase 3    | Fase      | 2 4      | Fase 5 |
| Nome da fase                                                                                                             |                                                                        |                      |       |         |          |           |          |        |
| D : 1                                                                                                                    |                                                                        |                      |       | 1       |          |           | L        |        |
| Datapath                                                                                                                 | Т                                                                      |                      |       | 1       | _        |           |          |        |
| A                                                                                                                        |                                                                        |                      |       |         |          |           |          |        |
| В                                                                                                                        |                                                                        |                      |       |         |          |           |          |        |
| Data Register                                                                                                            |                                                                        |                      |       |         |          |           |          |        |
| ALU Result                                                                                                               |                                                                        |                      |       |         |          |           |          |        |
| ALU Out                                                                                                                  |                                                                        |                      |       |         |          |           |          |        |
| ALU Zero                                                                                                                 |                                                                        |                      |       |         |          |           |          |        |
| Controlo PCWrite PCWriteCond                                                                                             |                                                                        |                      |       |         |          |           |          |        |
| RegWrite                                                                                                                 |                                                                        |                      |       |         |          |           |          |        |
| MemRead                                                                                                                  |                                                                        |                      |       |         |          |           |          |        |
| MemWrite                                                                                                                 |                                                                        |                      |       |         |          |           |          |        |
| ALUOp                                                                                                                    |                                                                        |                      |       |         |          |           |          |        |
| IRWrite                                                                                                                  |                                                                        |                      |       |         |          |           |          |        |
| PCSource                                                                                                                 |                                                                        |                      |       |         |          |           |          |        |
|                                                                                                                          |                                                                        |                      |       |         |          |           |          |        |
| ALUSelA                                                                                                                  |                                                                        |                      |       |         |          |           |          |        |
| ALUSelB                                                                                                                  |                                                                        |                      |       |         |          |           |          |        |
| IorD<br>Mark D                                                                                                           |                                                                        |                      |       |         |          |           |          |        |
| MemtoReg                                                                                                                 |                                                                        |                      |       |         |          |           |          |        |
| RegDst                                                                                                                   |                                                                        |                      |       |         |          |           |          |        |